<?xml version='1.0' encoding='UTF-8' ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:h="http://xmlns.jcp.org/jsf/html"
      xmlns:ui="http://xmlns.jcp.org/jsf/facelets"
      xmlns:f="http://xmlns.jcp.org/jsf/core"
      xmlns:p="http://primefaces.org/ui">

    <ui:composition template="/template.xhtml">
        <ui:define name="title">
            <h:outputText value="Proveedores"></h:outputText>
        </ui:define>
        <ui:define name="cuerpo">
            <p:growl id="message" showDetail="true" />
            <h:form id="form" >                                        
                <p:panel header="Administración de Proveedores" style="font-size: small">                                            
                    <p:growl id="validacionMensaje" showDetail="true" autoUpdate="true"/>
                    <table width="100%" border="0">                    
                        <p:commandButton process="@this" style="margin-top: 10px" 
                                         action="#{proveedorBean.cargarNuevo()}" value="Crear" 
                                         icon="ui-icon-circle-plus"
                                         update="@form:dlDialog" oncomplete="PF('dlDialogVar').show()"/>
                    </table> 

                    <p:dataTable id="dtProveedores" var="item" value="#{proveedorBean.proveedores}" widgetVar="tablaProveedor"                                                                  
                                 emptyMessage="Sin Datos"
                                 style="margin-top: 10px; font-size: small"                                
                                 paginator="true" rows="10" rowKey="#{item.codProveedor}">

                        <f:facet name="header">
                            <p:outputPanel>
                                <h:outputText value="Buscar por todos los criterios:" />
                                <p:inputText id="globalFilter" onkeyup="PF('tablaProveedor').filter()" style="width:200px" placeholder="Ingrese la palabra clave"/>
                            </p:outputPanel>
                        </f:facet>                        

                        <p:column headerText="RUC" filterBy="#{item.ruc}" >
                            <div align="center">
                                <h:outputText value="#{item.ruc}"/>
                            </div>
                        </p:column>            

                        <p:column headerText="Proveedor" filterBy="#{item.nombre}" >
                            <div align="center">
                                <h:outputText value="#{item.nombre}"/>
                            </div>
                        </p:column>                      

                        <p:column headerText="Pais" filterBy="#{item.ciudad.pais.nombre}" >
                            <div align="center">
                                <h:outputText value="#{item.ciudad.pais.nombre}"/>
                            </div>
                        </p:column>                      

                        <p:column headerText="Ciudad" filterBy="#{item.ciudad.nombre}" >
                            <div align="center">
                                <h:outputText value="#{item.ciudad.nombre}"/>
                            </div>
                        </p:column>      

                        <p:column headerText="Herramientas" >                                                        
                            <div align="center">
                                <p:commandButton value="Modificar" action="#{proveedorBean.cargarModificar()}" update="@form:dlDialog"
                                                 process="@this" oncomplete="PF('dlDialogVar').show()">
                                    <f:setPropertyActionListener value="#{item}" target="#{proveedorBean.proveedor}" />
                                </p:commandButton>  | 

                                <p:commandButton value="Detalles" action="#{proveedorBean.cargarDetalle()}" update="@form:dlDialog" 
                                                 process="@this" oncomplete="PF('dlDialogVar').show()">
                                    <f:setPropertyActionListener value="#{item}" target="#{proveedorBean.proveedor}" />
                                </p:commandButton>  
                            </div>
                        </p:column>                                                            
                    </p:dataTable>

                    <p:dialog dynamic="true" id="dlDialog" resizable="false" header="#{proveedorBean.tituloDialogo}" appendTo="@(body)" 
                              widgetVar="dlDialogVar" modal="true" showEffect="fade" hideEffect="fade"
                              style="font-size: small">                      
                        <p:panel  id="dlProveedor" style="text-align:center;">
                            <p:panelGrid columns="2" rendered="#{not empty proveedorBean.proveedor}" columnClasses="label,value">                                                                                        

                                <p:outputLabel  for="txtRUC" value="RUC:" />
                                <p:inputText onkeyup="value = value.toUpperCase();" 
                                             style="width: 200px" id="txtRUC" 
                                             value="#{proveedorBean.proveedor.ruc}" 
                                             required="true" 
                                             requiredMessage="El campo 'RUC' es requerido" 
                                             readonly="#{proveedorBean.soloLectura}" />                                

                                <p:outputLabel  for="txtNombre" value="Nombre:" />
                                <p:inputText onkeyup="value = value.toUpperCase();" 
                                             style="width: 200px" id="txtNombre" 
                                             value="#{proveedorBean.proveedor.nombre}" 
                                             required="true" 
                                             requiredMessage="El campo 'Nombre' es requerido" 
                                             readonly="#{proveedorBean.soloLectura}" />

                                <p:outputLabel  for="cmbCiudad" value="Ciudad:" />
                                <p:selectOneMenu filter="true" filterMatchMode="startsWith" disabled="#{proveedorBean.soloLectura}" 
                                                 id="cmbCiudad" value="#{proveedorBean.proveedor.ciudad}" 
                                                 required="true" requiredMessage="El campo 'Ciudad' es requerido" style="width: 200px" 
                                                 styleClass="menu" panelStyleClass="panel">                                                                        
                                    <f:selectItem itemLabel="Selecciones..." itemValue="#{null}" noSelectionOption="true" />
                                    <f:selectItems value="#{ciudadBean.ciudades}" var="ciudad" 
                                                   itemLabel="#{ciudad.nombre}" itemValue="#{ciudad}"/>
                                    <f:converter converterId = "ciudadConverter"/>                                     
                                </p:selectOneMenu>                               

                                <p:outputLabel  for="txtDireccion" value="Direccion:" />
                                <p:inputText onkeyup="value = value.toUpperCase();" 
                                             style="width: 200px" id="txtDireccion" 
                                             value="#{proveedorBean.proveedor.direccion}" 
                                             required="true" 
                                             requiredMessage="El campo 'Direccion' es requerido" 
                                             readonly="#{proveedorBean.soloLectura}" />
                                
                                <p:outputLabel  for="txtTelefono" value="Telefono:" />
                                <p:inputText onkeyup="value = value.toUpperCase();" 
                                             style="width: 200px" id="txtTelefono" 
                                             value="#{proveedorBean.proveedor.telefono}" 
                                             required="true" 
                                             requiredMessage="El campo 'Telefono' es requerido" 
                                             readonly="#{proveedorBean.soloLectura}" />
                                
                                
                                <p:outputLabel rendered="#{proveedorBean.soloLectura}" for="txtFechaCreacion" value="Fecha de Creación:" />
                                <p:inputText style="width: 200px" rendered="#{proveedorBean.soloLectura}" id="txtFechaCreacion"  value="#{proveedorBean.proveedor.fechaCreacion}" readonly="true" >
                                    <f:convertDateTime type="date" locale="es_EC" timeZone="America/Guayaquil"  
                                                       dateStyle="default" pattern="yyyy/dd/MM" /> 
                                </p:inputText>

                                <p:outputLabel rendered="#{proveedorBean.activarModificar || proveedorBean.soloLectura}" for="txtEstado" value="Estado:" />
                                <p:selectBooleanCheckbox style="text-align: center" rendered="#{proveedorBean.activarModificar || proveedorBean.soloLectura}" disabled="#{proveedorBean.soloLectura}" id="txtEstado" value="#{proveedorBean.proveedor.estado}"/>

                            </p:panelGrid>
                            <div align="right">
                                <p:outputLabel value = "* Campos Obligatorios"/>
                            </div>
                            <br/>
                            <div align="center">
                                <p:commandButton rendered="#{proveedorBean.activarNuevo}" 
                                                 update=":form:dtProveedores,@form:dlDialog:dlProveedor"
                                                 icon="ui-icon-disk"
                                                 action="#{proveedorBean.guardar()}" 
                                                 partialSubmit="true" process="@form:dlDialog"
                                                 value="Guardar">                                  
                                    <p:confirm header="Confirmación" message="Esta seguro de guardar este registro?" icon="ui-icon-alert" />
                                </p:commandButton>                                                                     
                            </div>
                            <div align="center">
                                <p:commandButton rendered="#{proveedorBean.activarModificar}" 
                                                 update=":form:dtProveedores,@form:dlDialog:dlProveedor"
                                                 icon="ui-icon-pencil"
                                                 action="#{proveedorBean.modificar()}"  
                                                 partialSubmit="true" process="@form:dlDialog"
                                                 value="Modificar">                                  
                                    <p:confirm header="Confirmación" message="Esta seguro de modificar este registro?" icon="ui-icon-alert" />
                                </p:commandButton>                                     
                            </div>                            
                        </p:panel>
                    </p:dialog>
                </p:panel>
                <p:confirmDialog style="font-size: small" global="true" showEffect="fade" hideEffect="explode">
                    <p:commandButton value="Si" type="button" styleClass="ui-confirmdialog-yes" icon="ui-icon-check" />
                    <p:commandButton value="No" type="button" styleClass="ui-confirmdialog-no" icon="ui-icon-close" />
                </p:confirmDialog>
            </h:form>
        </ui:define>
    </ui:composition>
</html>
